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0 Pipelined processor. 

0 Data processing apparatus comprises a series of 
pipeline units each of which consists of a number of 
pipeline stages. The units are interconnected by a 
numt>er of parameter files, which provide a number 
of slots. Whenever an instruction is initiated in the 
pipeline, it is allocated a slot, and retains that slot 
until its execution is successfully completed. Two 
independent streams of instructions are scheduled 
through the pipeline, each being allocated a fixed 
number of the slots. In normal operation, one of the 
streams has priority over the other stream. An in- 
struction is allowed to change the process state only 
when it successfully terminates at the end of the 
pipeline, thus ensuring consistency. An instruction 
can be started in a lower pipeline unit as soon as it 
is known that its required operand will be available in 
time from the data slave, thus allowing the oper- 
ations of these two units to be overlapped. 
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DATA PROCESSING APPARATUS 



This invention r lates to data proc ssing ap- 
paratus of the kind having a series of stages which 
execute successive instructions in an overlapped 
nnanner. Such apparatus is usually referred to as a 
pipelined processor. 

In such apparatus, by increasing the number of 
processing stages, the degree of concurrency in 
the execution of successive instructions can be 
increased, and hence the overall execution speed 
can be increased. 

However, with conventional pipeline organisa- 
tions, the co-ordination and control of a large num- 
ber of pipelines stages presents problems. 

One object of the present invention is to pro- 
vide a novel organisation for such a pipelined pro- 
cessor, which facilitates the co-ordination and con- 
trol of a large number of pipeline stages. 



Summary of the Invention 

According to the Invention, there is provided 
data processing apparatus comprising: 

(a) a plurality of pipeline units each of which 
comprises a plurality of pipeline stages connected 
in series for executing a sequence of instructions in 
a pipelined manner. 

(b) a plurality of parameter files, each of 
which comprises a plurality of individually selec- 
table registers, the parameter files thus providing a 
plurality of slots each of which comprises a set of 
registers, one from each of the parameter files, 
each parameter file being connected between a 
pair of said pipeline units, for passing parameters 
from one of those units to the other, and 

(c) means for allocating a slot to each in- 
struction when execution of that instruction is ini- 
tiated, and for deallocating that slot when the ex- 
ecution of the instruction is successfully completed. 



Brief Description of the Drawings 

One processing apparatus in accordance with 
the invention will now be described by way of 
example with reference to the accompanying draw- 
ings. 

Figure 1 is an overall diagram of the appara- 
tus. 

Rgure 2 shows an upper pipeiin unit in 
more detail. 

Rgure 3 shows a fast data slave store in 
more detail. 

Rgure 4 shows a lower pipeiin unit in more 

detail. 



Rgure 5 shows slot pointers for controlling 
the flow of instructions through the pipeline units. 

Rgure 6 to 8 show control logic for control- 
ling the initiation of instructions in the upper pipe- 
5 line. 

Rgure 9 shows look-ahead mode control 

logic. 

Rgure 10 and 11 show control logic for 
controlling the initiation of instructions in the lower 
10 pipeline. 



Description of an embodiment of the Invention 

75 

Overall description of System 

Referring to Rgure 1. the data processing ap- 
paratus comprises a series of pipeline units as 
20 follows: 

an instruction scheduler 10, an upper pipeline unit 
11, a fast data slave store 12. and a lower pipeiin 
unit 13. 

. The pipeline units 10-13 are interconnected by 

25 parameter files as follows: 

an instruction parameter file IFF, an address pa- 
rameter file APF. and an operand parameter file 
OPF. These allow instruction parameters to b 
passed between the pipeline units. 

30 The scheduler 10 has a fast code slave 14 

associated with it. for holding copies of instructions 
for access by the scheduler. 

The system also includes a main store 15 of 
larger size but slower access speed than the slave 

35 stores. 12. 14. and a slow slave store 16 of size 
and speed intermediate between those of the main 
store and the fast slaves. The fast slaves, the slow 
slave, and the main store form a three-level storage 
hierarchy. 

40. The scheduler 10 comprises two scheduler 

units 10A and 10B, for scheduling two separate 
streams of instructions, referred to as stream A and 
stream B. Stream A is dedicated to the main pro- 
cessing workload of the system. Stream B handles 

45 events that are independent of this main process- 
ing workload, such as managing input/output activ- 
ity, and communication with other processors. The 
provision of two independent streams allows more 
effective use of the hardware of the system. For 

50 example, as will be shown, wh n one stream Is 
held up for some reason, the other stream can 
continue processing, so that the hardware is not 
idle. 

Each of the scheduler units 10A, 108 gen- 
erates a sequence of instruction address s, for 
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r trieving instaictions from the code slave 14. If the 
required instruction is not in the code slave, it is 
retrieved from the slow slave 16 or from the main 
store 15. The retrieved instructions are written into 
the IPF. Each instruction is accompanied by a 
program counter value PC which is also written Into 
a portion of the IPF referred to as IPF.pc. The IPF 
has dual ports, so that the scheduler units 10A, 
10B can load the IPF simultaneously. 

Each of the parameter files IPF, APF and OPF 
(as well as another parameter file TPF to be de- 
scribed later) comprises sixteen registers, and can 
therefore hold parameters for up to sixteen different 
instructions at various stages of execution. The set 
of registers relating to a particular instruction is 
referred to as a slot: that is. each slot comprises a 
corresponding register from each of the register 
files. 

Ten of the slots are allocated to stream A and 
six to stream B. 

When an instruction is initially entered into the 
IPF from the scheduler, it is assigned a slot i.e. it is 
assigned a register in IPF and a corresponding 
register in each of the other parameter files. The 
instruction then retains this slot until it has been 
successfully executed by all stages of each pipe- 
line unit, whereupon the slot is released so that it is 
available for another instruction from the scheduler. 
As an instruction passes down the pipeline, the slot 
number assigned to that instruction is passed down 
the pipeline with it. so that at each pipeline stage 
the appropriate register in the parameter file can be 
accessed. 

The upper pipeline 11 reads instructions from 
the IPF and processes them, so as to calculate the 
address of the required operand for the instruction. 
This may, for example, involve adding a displace- 
ment value to a base address held in an internal 
register, such as a local name base register. Alter- 
natively, the address may be a literal value held in 
the instruction. The operand address is placed In 
the APF in the slot appropriate to the instruction in 
question. 

The data slave 12, when it is free, reads an 
address from the APF and retrieves the required 
operand, if it is present in the data slave, or alter* 
natively initiates fetching of the operand from the 
slow slave or the main store. The retrieved operand 
is placed in the OPF in the slot appropriate to the 
instruction in question. Additionally, data from the 
slave may be returned to the upper pipeline so as 
to update one of the internal registers in that unit. 

The lower pipeline 13 reads the operand from 
the OPF and performs the required operation on it 
as specified by the instruction. For example, this 
may involve adding the operand to the contents of 
an accumulator register. 



Upper Pipeline 

Referring now to Rgure 2, this shows the up- 
per pipeline unit 1 1 in more detail. 
5 The upper pipeline unit includes five pipeline 

stages referred to as UPO - UP4. 

The first stage UPO contains logic, to be de- 
scribed below, for selecting a slot from the IPF. so 
as to initiate processing of the instruction in that 
10 slot. 

Normally, instructions in each stream are start- 
ed in the upper pipeline in chronological order. 
Also normally, stream A is given priority over 
stream B, so that a B-stream instruction is started 

75 only if there are no A-stream instructions available 
in IPF. However, stream B may be given priority in 
certain circumstances. 

After an instruction has been started, the upper 
♦ pipeline may detect that the instruction cannot be 

20 successfully completed yet. t)ecause of a depen- 
dency on an earlier Instruction. In this case, the 
instruction Is abandoned. However Instructions fol- 
lowing the abandoned instruction are allowed to 
continue running in a special mode called look- 

25 ahead mode, the purpose of which is to allow 
operands for the instruction to be prefetched, if 
necessary, into the fast data slave. Such look 
aheads are allowed only if they do not generate 
any further dependencies. The look-ah ad mode 

30 can be initiated for streams A and B independently. 
When stream A is in look-ahead mode but not 
stream B, then stream B is given priority. When the 
dependency has been resolved, the stream is re- 
turned to normal non-look-ahead mode, and the 

35 abandoned instruction is restarted in the upper 
pipeline. 

UP1 comprises a decoder 20 which decodes 
the instruction from the selected slot to generate 
control signals for UP2. these being stored in a 

40 pipeline register 21 . The decoder 20 also produc s 
an output signal which is passed to UP2 for further 
decoding, by way of a register 23. 

UP2 contains a set of registers 24 which repre- 
sent local copies of the registers specified by the 

45 instruction set of the system. The definitive copies 
of these registers are actually in the lower pipeline. 
UP2 also contains a multiplexing circuit 25. which 
is controlled by the value in register 21 and which 
selects input data for the registers 24 from one of 

50 the following sources: 

(a) An output data signal V from the lower 
pipeline. 

(b) A corrected register value UP.CORR 
from the lower pipeline. 

55 (c) A data signal RD from the data slave. 

UP2 also contains a decoder 26 which further 
decodes the contents of register 23 to produce a 
set of control signals for UP3. these being stored in 
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a register 27. The decoder also produces a func- 
tion code F which is stored in a register 28. 

UP3 comprises a multiplexing circuit 29 which 
selects input data for a set of arithmetic registers 
210, under control of the value in register 27. The 
input data is selected from the following sources: 

(a) A literal value N, which is obtained from 
the decoder 20 in UP1 by way of pipeline registers 
211.212. 

(b) A program counter value PC, which is 
obtained from IPF.pc by way of pipeline registers 
213, 214. and 217. 

(c) The registers 24. 

UP3 also contains a register 215 which passes 
the function code F to UP4. The function code F is 
also passed from UP3 to the parameter files APF 
and OPF where it Is stored in the appropriate slot. 
The portions of these parameter files which store 
the function code are referred to as APF.F and 
OPF.F. 

UP4 contains an arithmetic and logic unit (ALU) 
216. which performs an operation on the contents 
of the registers 210 under control of the function 
code F in the register 21 5. The result of the opera- 
tion is passed to the APF, where it Is written into 
the appropriate slot. 

In a further stage UPS (not shown), the address 
generated In UP4 may be checked for architectural 
validity. Any error will cause a later unsuccessful 
termination of this slot 



Data Slave 

Referring now to Rgure 3, this shows the fast 
data slave 1 2 in more detail. 

The data slave includes five pipeline stages 
DSO - DS4. 

The first stage DSO comprises a priority logic 
circuit for selecting the next slot from the APF to 
be handled by the data slave. 

OSl contains a decoder 30 which decodes the 
address selected from APF. to produce a byte shift 
value indicating the alignment of the required data 
item within a 32-byte block. The address and the 
byte shift value are passed to DS2 by way of 
registers 31 and 32. 

DS2 comprises a contents - addressable mem- 
ory (CAM) 33, which holds the addresses of data 
items currently in the data slave. The CAM 33 
receives the operand address from DS1 , and com- 
pares it with all the addresses held In the CAM. if 
there is a match, the CAM produces a signal VHIT. 
and at the same time outputs a tag value indicating 
which 32-byte block of th data slave the required 
item is held in. The tag vaiu is pass d to DS3 by 
way of a register 34. 

If the required data Item is not In the data slave 



(VHIT false), the data slave triggers an acc ss to 
the slow slave, which will cause the data to be 
fetched, either from the slow slave or the main 
store, and loaded into the data slave. 

5 The DS2 also includes a byte alignm nt circuit 

35 which receives a data item W from the lower 
pipeline and aligns it according to the byte shift 
value held in the register 32. The aligned data item 
is stored in a register 36. DS2 also includes regis- 

10 ters 37 and 38 which receive data items returned to 
the data slave from the main store and slow slave 
respectively. 

0S3 comprises a random-access memory 
(RAM) 39 which holds a number of individually 

75 addressable 32-byte blocks of data. The RAM is 
addressed by the tag value from register 34. Data 
can be written into the RAM. by way of a mul- 
tiplexer 310, from any of the registers 36. 37 and 
38. Alternatively, a block of data can be read out of 

20 the RAM and passed to 0S4 by way of a register 
311. 

DS4 comprises a byte alignment circuit 312. 
This is controlled by a byte shift value, received 
from the decoder 40 by way of pipeline registers 
25 32. 313 and 314. The alignment circuit 312 selects 
the required data item from the block held in regis- 
ter 311, and passes it to the OPF. The selected 
data item Is also supplied to the upper and lower 
pipelines as data signal RD. 

30 

Lower Pipeline 

Referring now to Rgure 4, this shows the lower 
35 pipeline 13 in more detail. 

The lower pipeline includes four pipeline 
stages LPO - LP3 

The first stage LPO contains a priority logic, to 
be described, for selecting the next slot from OPF 
40 to be handled by the lower pipeline. 

Within each stream, instructions are started, 
(and hence finish) in strict chronological order, 
starting with the eldest. 

The execution of an instruction in the lower 
<5 pipeline may be started as soon as it is certain that 
the operand for it will be available from the data 
slave in time for use at stage LP2 of the lower 
pipeline. Thus, an instruction may be started in the 
lower pipeline while the data item is actually being 
50 retrieved from the data slave. In the limiting case, 
the data signal RD from the data slave is used 
directly in LP1, bypassing OPF. Hence, operations 
of th pipeline stages of the data slave and the 
lower pipelin can be overlapped. This is impor- 
55 tant. 

since it reduces the total transit time of instructions 
through the overall pipeline. 

LP1 comprises a control store 40 having an 
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address Input which receives the Junction code F 
from the selected slot of OPF.f, by way of a mul- 
tiplexer 41. The output of the control store 40 
comprises a control code, and a next address 
value. The control code is passed to LP2 by way of 
a register 42. The next address value is fed back to 
a register 43 in LPO, and can then be selected by 
the multiplexer 41 so as to address another loca- 
tion in the control store 40. Thus it can be seen 
that, for each function code F, the control store 40 
can produce a sequence of control codes for the 
lower pipeline. At the end of the sequence of 
control codes, the control store produces an end of 
sequence signal, which tells the priority logic in 
stage LPO to select a new slot, and switches the 
multiplexer 41 so as to select the next function 
code from OPF.f, thus initiating a new sequence, 

LP1 also includes a set of arithmetic registers 
44. Data can be loaded into these registers by way 
of a multiplexing circuit 45 from either the following 
sources: 

(a) The operand held in the currently se- 
lected slot of the OPF. 

(b) Data from the registers in LP3 

(c) Slave data RD directly from the data 
slave (OPF bypass) 

Multiplexer 45 can also take bypass data from 
registers 47 or ALU 46, where that data has not yet 
been written into the required register 41 1 . 

LP2 comprises an arithmetic and logic unit 
(ALU) 46 which performs an operation on the con- 
tents of registers 44 as specified by the control 
held in register 42. The result of this operation Is 
passed to LPS by way of registers 47 and 48. 

LP2 also contains another parameter file, re- 
ferred to as the termination parameter file TPF. 
Like the other parameter files, TPF comprises six- 
teen registers, one for each slot Whenever an 
instruction detects a problem in execution in any of 
the pipeline units, an indicator is set in the slot of 
TPF corresponding to that instruction. 

LPS includes a condition logic circuit 412 which 
receives the output of the register 48 and a control 
signal from the control store 40 by way of registers 
42 and 410. The circuit 412 performs tests to 
detect whether a jump condition specified by the 
instruction has been satisfied, e.g. whether an ac- 
cumulator register is zero. If the jump condition is 
satisfied, the circuit 412 produces a jump signal 
JCON for the scheduler 10. 

LPS contains finish logic 49, which receives a 
control signal from the condition logic 412 to in- 
dicate whether any problems have been detected 
during execution in LP2. The logic 49 examines the 
signal and the contents of TPF corresponding to 
the instruction, and determines whether this in- 
struction has encountered any problems during ex- 
ecution. When successful completion is detected, 



the circuit produces one of two signals AFinOK or 
BFinOK, depending on which stream the instruction 
is in. The slot allocated to the instruction is then 
released for re-use. 

5 LPS also includes a set of registers 411 which 

represents the definitive copies of the registers 
specif i.d by the instruction set of the system. 
These registers receive data from the regist r 47. 
The registers 41 1 are loaded from register 47 only 

70 when the finish logic 49 indicates that this slot is 
completing successfully. In this way. the cun^ent 
process state, as defined in registers 411. is not 
corrupted by any errors in the execution of an 
instruction. The output of the registers 411 pro- 

15 vides the correction signal UP.CORR which can be 
fed back to the upper pipeline if required, to cor- 
rect the local copies of the registers held there. 

The output of the register 47 also provides the 
signal W to the data slave, and the signal V to the 

20 upper pipeline. 



Slot pointers . 

25 Referring now to Figure 5. the flow of A-stream 

instructions through the pipeline is controlled by a 
plurality of counters 50-54. A similar set of coun- 
ters (not shown) is provided for the B-stream. 

Counter 50 produces a signal ALdSIt which 

30 indicates the next slot in the IPF to be loaded by 
an A-stream instruction from the scheduler. The 
counter 50 is incremented by a signal APiLd when- 
ever an A-stream instruction is loaded into the IPF. 
Thus the slots in the IPF are allocated sequentially 

35 to successive instructions. 

Counter 51 produces a signal AUStSIt which 
indicates the next A-stream slot to be started in the 
upper pipeline UP in normal mode (i.e. non-look- 
ahead mode). Similarly, counter 52 produces a 

40 signal AULaStSlt which indicates the next A-stream 
slot to be started in the upper pipeline in look- 
ahead mode. 

Initially, the contents of both the counters 51, 
52 are equal, this condition being detected by an 

45 equivalence gate 55. 

In normal mode, a look-ahead signal ALAmode 
is false. Each time an A-stream instruction is start- 
ed in the upper pipeline, a signal UPAStart goes 
true. This enables an AND gate 56 . which incre- 

50 ments the counter 51. Thus, in normal mode, the 
counter 51 selects A-stream instructions from suc- 
cessive slots of the IPF, so as to initiate processing 
of these instructions in the upper pipeline. At the 
same time, an AND gate 57 and an OR gate 58 are 

55 enabled, which increments the counter 52. Thus, 
while the system remains in normal mode, the two 
counters 51 , 52 are incremented in step with each 
other. 
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In look-ahead mode, ALAmode is true, and so 
the AND gate 56 is disabled, which prevents th 
counter 51 from being incremented. Each tinne a 
new A-stream instruction is started in look-ahead 
mode, an AND gate 59 is enabled, and this incre- 
ments the counter 52. Thus, in look-ahead mode, 
the counter 52 continues counting, so as to con- 
tinue to select successive instructions from the IPF 
for starting in the upper pipeline. The counter 51 , 
on the other hand, retains the slot number of the 
instruction which was abandoned. 

When the system returns to normal mode. AL- 
Amode goes false again. Thus, each time a new 
instruction is started in the upper pipeline, the AND 
gate 56 is enabled, and the counter 51 is incre- 
mented. However, while the contents of the coun- 
ters are unequal, the AND gate 57 remains inhib- 
ited and this prevents the counter 52 from being 
incremented. When the counter 51 eventually 
catches up with counter 52. both counters will 
again be incremented in step with each other. If 
another look ahead is initiated before the counter 
51 has caught up, those instructions that have 
already run in look-ahead mode will not do so 
again, since look-ahead starts from the current val- 
ue of counter 52. 

Counter 53 produces a signal ALStSIt which 
indicates the next A-stream slot to be started in the 
lower pipeline LP. This counter 53 is incremented 
by a signal LPAStart whenever an A-stream in- 
struction is started in the lower pipeline. Thus, the 
instructions are started sequentially in the lower 
pipeline. 

The counter 54 produces a signal AEIdSIt 
which indicates the slot holding the eldest A-stream 
instruction currently in the pipeline. Instructions are 
completed in strictly chronological order, and 
hence this signal indicates the next A-stream in- 
struction which is due to finish execution in the 
lower pipeline. The counter 54 is incremented by a 
signal AFinOK which indicates that an A-stream 
instruction has successfully completed execution in 
the lower pipeline. This releases the slot. 

The contents of the counters 50 and 51 are 
compared, to produce a signal AUAIISt. which in- 
dicates that all the A-stream instructions currently 
in the IPF have now been started in normal mode. 
Similarly, the contents of the counters 50 and 52 
are compared, to produce a signal AULaAIISt. 
which indicates that all the A-stream instructions 
currently in the IPF have now been started, with 
possibly some of them in look-ahead mode. 

The contents of th counters 50 and 54 are 
compared to pnDduce a signal AlpfFull which in- 
dicates that ail the A-stream slots in the IPF are 
now full. This prevents any further A-stream 
instructions from being loaded into the IPF. 



Upper pipeline start controls . 

Rgure 6 to 8 show the control logic for starting 
instructions in the upper pipeline. 
5 Referring toFigure 6. a multiplexer 60 sel cts 

either AUAIISt or AULaAIISt according to whether 
the signal ALAmode is false or true. The inverse of 
the output of the multiplexer 60 provides a signal 
AlpfRdy which indicates that there is at least one 
70 A-stream instruction in the IPF ready to be started 
in the upper pipeline. A similar signal BIpfRdY is 
produced for the B-stream. 

The signal AlpfRdy is fed to one input of an 
AND gate 61, which produces a signal UPAStart. 
15 for initiating an A-stream instruction in the upper 
pipeline. The other input of this AND gate receives 
the output of an OR gate 62, which receives the 
inverse of BIpfRdy and the inverse of a priority 
signal UPBStPrefd. 

20 Similarly, BIpfRdy is fed to one input of an 

AND gate 63, which produces a signal UPBStart. 
for initiating a B-stream instruction in the upper 
pipeline. The other input of this AND gate receives 
the output of an OR gate 64, which receives UPB- 

25 StPrefd and the inverse AlpfRdy. 

Thus it can be seen that, when UPBStPrefd is 
false, A-stream instructions are initiated in pref- 
erence to B-stream instructions: a B-stream instruc- 
tion can be initiated only if there are no A-stream 

30 instructions ready. Conversely, when UPBStPrefd 
is true. B-stream instructions are initiated in pref- 
erence to ArStream instructions. 

Referring to Rgure 7. a multiplexer 70 selects 
either AUStSIt or AULaStSIt according to whether 

35 ALAmode is false or true. The output of this mul- 
tiplexer therefore indicates the slot number of the 
next A-stream instruction to be started in the upper 
pipeline, in normal or look-ahead mode as the case 
may be. A similar multiplexer 71 is provided for the 

40 B-stream. 

The outputs of the multiplexers are gated by 
way of AND gates 72. 73 to an OR gate 74, the 
output of which provides a signal IpfRdSIt This 
signal is used to address the IPF. for reading out 

45 the next instruction for starting in the upper pipe- 
line. 

The AND gates 72, 73 are controlled by signals 
UPAStart and UPBStart as shown, so as to select 
the slot number for the A stream or B stream as 

50 required. 

Referring now to Rgure 8. this shows the logic 
for producing the signal UPBStprefd which indi- 
cates that the B stream is preferred for starting in 
the upper pipeline. 

55 UPBStprefd is derived from an OR gate 80 

which receiv s the output of two AND gat s 81 and 
82, AND gate 81 receives the signal ALAmode and 
the inverse of the corresponding signal BLAmode 
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for the B-stream. Gate 82 receives a signal UPBPri, 
and the output of an equivalence gat 83. which 
combines ALAmode and BLAmode. 

Thus, it can be seen that if one of the two 
stream is in look-ahead mode, and the other Is in 
normal mode, the signal UPBStPrefd gives pref- 
erence to the stream that is in normal mode. If, on 
the other hand, both streams are in the same 
mode, then preference is given to the A stream or 
the B stream according to whether UPBPri is false 
or true. 

The signal UPBPri is produced as follows. 

A counter 84 is loaded with a preset value 
USPlim whenever a B-stream instruction is started 
in the upper pipeline, as indicated by UPBStart. 
The counter is then decremented whenever an A- 
stream instruction is started, as indicated by UP- 
AStart. When the count reaches zero an AND gate 
85 is enabled, which in turn enables OR gate 87. 
so as to make UPBPri true. Thus, it can be seen 
that the A stream is normally given priority, but the 
B stream is given priority if a predetermined num- 
ber of A-stream instructions are started without any 
corresponding B-stream starts. The values of 
USPlim can be preset to a value such as to 
achieve a desired balance between the two 
streams. 

The OR gate 87 also receives a signal BUr- 
gent. which gives priority to the B-stream when 
pending input^output activity or inter-processor 
communication has become critical, over-riding the 
effect of the counter 84. 



Look-ahead control logic. 

As mentioned above, if it is detected that an 
instruction cannot be completed yet because of a 
dependency on an earlier Instruction, it is aban- 
doned, and a look-ahead mode is initiated. 

Referring to Figure 9. this shows the logic for 
controlling the look ahead mode. 

If the instruction to be abandoned is In the A- 
stream, signals AAbnDep and ADepWait are pro- 
duced. AAbnDep sets a flip flop 90. The output of 
this flip flop, along with ADepWait. then enables an 
AND gate 91, to produce the signal ALAmode. 
which puts the A stream into look-ahead mode. 

As described above, in look-ahead mode, 
instructions continue to be initiated, under control 
of the counter 52 (Rgure 5). Thus. Instructions 
following the abandoned instruction are allowed to 
continue running, so as to priefetch operands, if 
necessary. However, these instructions are not al- 
lowed to terminate successfully, or to update the 
definitive copies of the register in the lower pipe- 
line. 

The signal ADepWait goes fals again when it 



is detected that the dependency has now been 
resolved, or is likely to be resolved shortly. This 
disables AND gate 91 , making ALAmod false, and 
at the same time enables an AND gate 92, produc- 
5 ing a signal AReStRdy. 

Since ALAmode is now false, the next A 
stream instruction to be initiated will be the instnjc- 
tion in the slot indicated by AUStSlt. In other 
words, the instruction that was abandoned because 
70 of the dependency will now be restarted. 

When the instruction is restarted, the signals 
UPAStart and ARestRdy enable an AND gate 93. 
producing a signal ARestarted, which resets the flip 
flop 90. 

75 Similar logic (not shown) exists for generating 

the signal BLAmode for the B stream. 

It should be noted that an abandoned instruc- 
tion may be restarted before the dependency has 
actually been resolved. For example, consider the 

20 case where an instruction has been abandoned 
because it requires to read data from a register that 
has not yet been written from the slave output data 
RD of an earlier instruction. In this case, the signal 
ADepWait will go false as soon as an access is 

25 initiated in the data slave to retrieve the required 
data. Thus, the restarted instruction will start run- 
ning in the upper pipeline in parallel with the ac-* 
cess to the data slave by the earlier instruction. By 
the time the restarted instruction requires to read 

30 the data, it is likely that the -data will have be n 
accessed from the data slave, and so execution will 
proceed normally. However, If the required data is 
not in the data slave, the restarted instruction will 
be abandoned again, and look-ahead mode is re- 

35 activated. 



Lower pipeline start controls . 

40 Rgures 10 and 11 show the control logic for 

starting instructions in the lower pipeline LP. 

Referring to Figure 10. when the first stage 
LPO of the lower pipeline Is available to start 
executing an instruction, a signal LPipeAv is pro- 

45 duced. 

A signal ADsDone is produced, to indicate that 
the required data slave access (if any) for th A 
stream has been completed or is expect d to be 
completed shortly. This signal consists of t n bits, 

50 one for each a stream slot. These ten bits are 
applied to a multiplexer 100. which selects the bit 
corresponding to the next A-stream instruction to 
be started in the lower pipeline, as indicated by 
ALStSlt. 

55 The signal LPipeAv. and the output of the 

multiplexer 100 are combined in an AND gate 101 
to produce a signal LPAStartPoss. which indicates 
that it is now possible to start a new A-stream 
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instruction in the lower pipeline. 

Similar logic exists as shown to produce a 
corresponding signal LPBStartPoss for B stream. 

The signal LPAStartPoss is applied to one in- 
pift of an AND gat 102, which produces a signal 
LPAStart, indicating that an A-stream instruction is 
to be started in the lower pipeline. The other input 
of this AND gate receives the output of an OR gate 
103, the Inputs of which receive the inverse of 
LPBStartPoss and the inverse of a priority control 
signal LPBPri. 

Similarly, the signal LPBStartPoss is applied to 
one input of an AND gate 104. which produces a 
signal LPBStart, indicating that a B-stream instruc- 
tion is to be started in the lower pipeline. The other 
input of this AND gate receives the output of an 
OR gate 105. the inputs of which receive the signal 
LPBPri and the inverse of LPAStartPoss. 

Thus, it can be seen that, if LPBPri is false, 
then an A-stream instruction is started whenever 
possible, in preference to a B-stream instruction. If 
LPBPri is true, then the B-stream instructions are 
given preference. 

The priority signal LPBPri is produced by a 
logic circuit similar to the circuit shown in Rgure 8 
for producing UPBPri. In this case, the counter is 
controlled by signals LPAStart and LPBStart. and 
the preset count value is LSPLim, which may be 
different from USPLim. 

It should be noted that the signals ADsDone 
and BDsOone can be produced as soon as the 
data slave knows it will be able to provide the 
requested data item without recourse to the slow 
slave or main store. In practice, the signals are 
produced at the same time as the data slave is 
being accessed. This means that the operation of 
the lower pipeline may be overlapped with the 
operation of the slave store, if production of ADs- 
Done or BDsDone results in an immediate LPAStrt 
or LPBStart for the same slot. 

Referring now to Rgure 11, this shows the 
logic for selecting the slot to be initiated in the 
lower pipeline. 

The signal ALStSlt. indicating the next A- 
str am slot to be started in the lower pipeline, is 
gated with U'AStart in a set of AND gates 110. 
Similarly. BLStSIt is gated with LPBStart in a set of 
AND gates 111. 

The outputs of gates 110 and 111 are com- 
bined in a set of OR gates 112, to produce a signal 
LPOSIt. which indicates the slot number of the next 
instruction, in the A-stream or B-stream as the case 
may be, to be started in the lower pipeline. LPOSIt 
is used to access the parameter file OPF so as to 
read put the required instruction and operand for 
the lower pipeline. 

The signal LPOSIt is stored in a register 113 
when the instruction enters stage LPl of the lower 



pipeline, to produce a signal LPISIt. This signal is 
gated back to the OR gates 1 12, by way of a set of 
AND gates 114, whenever LPipeAv is false. Thus, if 
the lower pipeline is not available to receive a new 

5 instruction (because it is executing a multi-beat 
instruction) the current slot number is maintained. 

It should be noted that, for each instruction, all 
changes to the process state are made at the same 
time, upon successful termination in state LP3, 

10 Thus, instructions can be considered atomic, being 
executed either in full or not at all. This simplifies 
control and recovery of the pipeline on jumps and 
errors. 

75 

Claims 

1 . Data processing apparatus comprising a plu- 
rality of pipeline stages, characterised in that: 

20 (a) the pipeline stages are grouped into a 

plurality of pipeline units (11. 12, 13) each of which 
comprises a plurality of pipeline stages (UPO. 
UP1... DSO. DS1.., LPO, LPl..) connected in series 
for executing a sequence of instaictions in an 

25 pipelined manner, 

(b) the pipeline units are interconnected by a 
plurality of parameter files (IPF. APR, OPF), each of 
which comprises a plurality of individually selec- 
table registers, the parameter files thus providing a 

30 plurality of slots each of which comprises a set of 
registers, one from each of the parameter files, 
each parameter file being connected between a 
pair of said pipeline units, for passing parameters 
from one of those units to the other, and 

3S (c) a slot is allocated to each instruction 

when execution of that instruction is initiated, the 
slot being deallocated when the execution of the 
instruction is successfully completed. 

2. Apparatus according to claim 1 including 
40 means for generating first and second independent 

streams of instructions, and wherein each of the 
pipeline units processes instructions from both 
streams. 

3. Apparatus according to claim 2 wherein with- 
45 in each stream instructions are terminated in strict 

chronological order. 

4. Apparatus according to claim 2 or 3 wherein 
at least one of the pipeline units comprises priority 
means (80-87) for indicating which of the two 

50 streams has priority, and for normally selecting 
instructions from that stream in preference to 
instructions from the other stream. 

5. Apparatus according to claim 4 wh rein said 
priority means normally indicates that the first 

55 Stream has priority, and indicates that the second 
stream has priority after a predetermined number 
of instructions from the first stream have been 
selected without any instructions from the second 
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stream being selected. 

6. Apparatus according to claim 2. wherein 
each of the pipeline units independently selects 
instructions from th two streams for processing. 

7. Apparatus according to any preceding claim 
wherein the pipeline units comprise: 

(a) an instruction scheduler (10) for produc- 
ing said sequence of instructions, 

(b) an upper pipeline unit (11) for generating 
operand addresses for the instructions, 

(c) a data slave store (12) for retrieving the 
operands, and 

(d) a lower pipeline unit (13) for performing 
operations on said operands. 

8. Apparatus according to claim 7 wherein said 
parameter files comprise: 

(a) an instruction parameter file (IPF) for 
passing the instructions from the scheduler to the 
upper pipeline, 

(b) an address parameter file (APF) for pass- 
ing the operand addresses from the upper pipeline 
to the data slave store, and 

(c) an operand parameter file (OPF) for pass- 
ing the operands from the data slave store to the 
lower pipeline. 

9. Apparatus according to claim 8 wherein the 
operand parameter file also passes function codes 
from the upper pipeline to the lower pipeline, 

10. Apparatus according to any preceding 
claim wherein said parameter flies include a ter- 
mination parameter file (TPF) for storing informa- 
tion regarding errors detected on completion of 
each Instruction by said pipeline units. 

11. Apparatus according to any preceding 
wherein the slots are allocated in a predetermined 
cyclic order. 

12. Apparatus according to any preceding 
claim, wherein a first one of said pipeline units (12) 
initiates processing of an instruction in a second 
one of the pipeline units (13) before that instruction 
has reached the last pipeline stage (DS4) of the 
first pipeline unit, upon detection of a condition 
indicating that said instruction will successfully 
complete its processing in the first pipeline unit so 
that the operations of said first and second pipeline 
units are overlapped. 

13. Apparatus according to Claim 12 wherein 
said first pipeline unit comprises a data slave store 
and said second pipeline unit is an execution unit 
for performing an operation on an operand re- 
trieved from the data slave store, wherein said 
condition is that the operand is present in the data 
slave store 

14. Apparatus according to any preceding 
claim, including a plurality of registers defining a 
process state of the apparatus, wherein ach ir>- 
struction is p rmitted to update the process state 
only when execution of the instruction has been 



successfully completed by all the pipeline units. 
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(§) Pipelined processor. 

@ Data processing apparatus comprises a series of 
pipeline units each of which consists of a number of 
pipeline stages. The units are interconnected by a 
number of parameter files, which provide a number 
of slots. Whenever an instruction is initiated in the 
pipeline. It Is allocated a slot, and retains that slot 
until its execution is successfully completed. Two 
independent streams of instructions are scheduled 
through the pipeline, each being allocated a fixed 
number of the slots. In normal operation, one of the 
streams has priority over the other stream. An in- 
struction is allowed to change the process state only 
when it successfully terminates at the end of the 
pipeline, thus ensuring consistency. An instruction 
can be started in a lower pipeline unit as soon as it 
is known that its required operand will be available in 
time from the data slave, thus allowing the oper- 
ations of these two units to be overlapped. 
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